package sort;

import java.util.Arrays;

public class InsertionSort {
    public static void main(String[] args) {
        int[] a = {100, 250, 5, 6, 85, 24, 14, 10, 52, 30, 15, 34, 64};
        System.out.println(Arrays.toString(a));
        sort(a);
        System.out.println(Arrays.toString(a));
    }

    /*
    1. i循环从下标1开始递增到末尾
    2. i位置值先拿出来存到一个临时变量
    3. j循环从i-1递减一直到0位置
    4. j循环中，j位置的值>tmp，j位置的值复制到j+1位置
    5. j位置值不大,j循环结束
    6. j循环结束，临时值放到j+1位置
     */

    //插入排序
    private static void sort(int[] a) {
        for (int i = 1; i < a.length; i++) {
            int tmp = a[i];
            int j;
            for (j = i - 1; j >= 0; j--) {
                if (a[j] > tmp) {
                    a[j + 1] = a[j];
                } else {
                    break;
                }
            }
            a[j + 1] = tmp;
        }
    }
}
